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shared memory, any custom page can be built within the page server, eliminating the need to make requests from other servers for portions 
of the live data. While the shared memory might include RAM (random access memory) and disk storage, in many computer systems, it 
is faster to store all the live data in RAM. 
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COPYRIGHT NOTICE 
A portion of the disclosure of this patent document 
contains material which is subject to copyright protection. 
The copyright owner has no objection to the xerographic 
10 reproduction by anyone of the patent document or the patent 
disclosure in exactly the form it appears in the Patent and 
Trademark Office patent file or records, but otherwise 
reserves all copyright rights whatsoever. 

15 BACKGROUND OF THE INVENTION 

The present invention relates to the field of 
customized information presentation. More specifically, one 
embodiment of the invention provides a custom page server 
which can quickly serve custom pages and is scalable to handle 

20 many userjs simultaneously. 

Web servers for serving static documents ("Web 
pages") over the global Internet are known. While static 
documents are useful in many applications where the 
information to be presented to each requesting user is the 

25 same, some applications require customization to appeal to 

users. For example, in presenting news to users, custom pages 
present news which is more relevant to the requesting users 
than static pages. With static pages, a user will often have 
to scroll through many topics not of "interest to that user to 

30 get to the information of interest. With custom pages, the 
information is filtered according to each user's interest. 

Customizing a server response based on the requestor 
is known, however known systems do not scale well. One method 
of serving custom pages is to execute a script, such as a CGI 

35 (Common Gateway Interface) script, or other program to collect 
the information necessary to generate the custom page. For 
example, if the custom page is a news page containing stock 
quotes, sports scores and weather, the script might poll a 
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quote server to obtain the quotes of interest, poll a sports 
score server to obtain the scores of interest and poll a 
weather server to obtain the weather. With this information, 
the server generates the custom page and returns it to the 
5 user. This approach is useful where there are not many 
requestors and where the attendant delay is acceptable to 
users. While it may be the case that current users are 
willing to wait while pages load in their browsers, growing 
impatience with waiting will turn users away from such 

10 servers, especially as use increases. 

One approach to avoiding long waits is to transfer 
the custom information in non- real -time, so that the 
information is stored local to the user as it arrives and is 
presented to the user on request . A disadvantage of such a 

15 system is that the networks used by the user become clogged 
with data continually streaming to the user and require large 
amounts of local storage . Another disadvantage is that the 
locally stored information will become out of date as the 
server receives new data. 

20 From the above it is seen that an improved system 

for delivering custom pages is needed. 
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SUMMARY OF THE INVENTION 

An improved custom page server is provided by virtue 
of the present invention. In one embodiment, user preferences 
5 are organized into templates stored in compact data structures 
and the live data used to fill the templates is stored local 
to the page server which is handing user requests for custom 
pages. One process is executed on the page server for every 
request. The" process is provided a user template for the user 

10 making the request, where the user template is either 

generated from user preferences or retrieved from a cache of 
recently used user templates. Each user process is provided 
access to a large region of shared memory which contains all 
of the live data needed to fill any user template. Typically, 

15 the pages served kre news pages, giving the user a custom 
selection of stock quotes, news headlines , sports scores, 
weather, and the like. With the live data stored in a local, 
shared memory, any custom page can be built within the page 
server, eliminating the need to make requests from other 

20 servers for portions of the live data. While the shared 
memory might include RAM (random access memory) and disk 
storage, in many computer systems, it is faster to store all 
the live data in RAM. 

If the volume of requests becomes too great for one 

25 page server to handle, the system is easily scaled by adding 
additional page servers. Each page server maintains its own 
copy of the live data in its shared memory, and needs to 
maintain only the user templates for the requests it is 
handling, so no communication between* page servers is needed. 

30 A further understanding of the nature and advantages 

of the inventions herein may be realized by reference to the 
remaining portions of the specification and the attached 
drawings . 



35 BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of a client-server 
architecture according to one embodiment of the present 
invention; 
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FIG. 2 is a schematic diagram showing how a user's 
custom page is generated from a user configuration, a global 
template and live data. 

FIG. 3 is an illustration of a global front page 
5 template as might be used to generate user templates, 

FIG. 4 is an illustration of a user template 
generated from the global front page template of FIG. 3 as 
might be used to generate a custom user page. 

FIG, 5 is an illustration of a user page generated 
10 using the global template of FIG. 4. 

FIG. 6 is an illustration of how intelligent 
defaults are selected. 

Two appendices are included at the end of this 
description. Appendix A is a full listing of the user 
15 template shown in part in FIG. 4. Appendix B is an HTML source 
code listing of the HTML page used to generate the browser 
display shown in FIG. 5. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 

20 . FIG. 1 shows a client-server system 100 which is 

used to display custom news pages. A custom news page is 
displayed on. a browser 102 which obtains the page from a page 
server 104 via Internet 106. ■ While only one browser 102 is 
shown, a typical system will have many browsers connecting and 

25 disconnecting to the system. 

The art of client-server systems using HTTP 
(HyperText Transport Protocol) messaging or other protocols is 
well known and will not be addressed in detail here. 
Essentially, browser 102 makes a request" for a particular page 

30 by specifying a Uniform Resource Locator ("URL") for the page. 
In the example shown in FIG. 1, the request is directed to 
the URL " http: /my. yahoo. com/ n . Normally, this URL is directed 
to the root directory of a machine named my.yahoo.com. As is 
the convention in Internet communications, browser 102 submits 

35 the domain portion ( "my .yahoo.com" ) of the URL to a name 
server, such as name server 108, to determine an actual 
address for the page server 104. Name server 108 returns an 
IP (Internet Protocol) address to browser 102 directing it to 
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a page server 104. Where multiple page servers 104 are used, 
name server 108 returns IP addresses in a round-robin fashion 
to distribute the load over multiple page servers. 
Alternatively, name server 108 might distribute the load more 
5 deterministic by tracking browser addresses and hashing the 
browser address to select a page server 104 . It is 
deterministic in that any given browser always accesses the 
same page server 104. This allows for more efficient caching 
of user templates, since more cache hits are likely where a 

10 given browser always returns to one page server. 

When a page server receives the URL for its root 
directory, it interprets that as a request for the user's 
custom summary page. The user is determined not from the URL, 
but from a "cookie" provided by browser 102 with the URL. 

15 Cookies are strings of data stored by browsers and sent along 
with any request to a URL having a domain associated with the 
cookie . 

Page servers 104 obtain the live data from- many 
disparate sources and reformat the data into a form suitable 

2 0 for use by the page server. Page servers 104 are coupled, via 
a network, to edit servers 112, which are used when a user 
changes his or her user template. The user templates are 
stored in a user configuration database 116 and are stored and 
provided to edit servers by a network appliance 114 written 

25 for this purpose. Network appliance 114 is a process tuned to 
quickly locate files in large directories (N400 
files/directory) and return them to the edit servers or page 
servers. One embodiment of network appliance 114 is the F330 
fault -tolerant scalable server supplied* by Network Appliance, 

30 of Mountain View, California. 

In a specific embodiment, page servers 104 are 
microcomputers running the Unix® operating system with 64 to 
128 megabytes of shared memory, page servers 104 and edit 
servers 112 are coupled using TCP/IP (Transport Control 

35 Protocol/Internet Protocol) and the user configuration 

database 116 is a Unix file structure which stores each user 
configuration in a text file. The particular file used by a 
user is a combination of the user's user name and a hash 
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result, to allow for quick access when many user 
configurations are stored. For example, the user 
configuration for summary "front" page for a user "ash802 M 
might be stored at /de/l3/y.ash802, where "de" and "13" are 
5 hash results of a hash of the user name n ash802" . 

FIG. 2 shows in more detail the generation of a 
custom page for a user, using a front page generator 200 and 
page server 104. Front page generator 200 generates a user 
template 202 from a global front page template 204 and a user 

10 configuration record 206. FIG. 3 shows an example of a global 
front page template. User configuration record 206 is a 
record selected from user configuration database 116. The 
record might have been obtained from a cache, but in the 
preferred embodiment, the records are not cached, the user 

15 templates are. 

Page server 104 is shown comprising a page generator 
210, a shared memory 212 for storing live data and a cache 214 
for caching user templates such as user template 202. Page 
generator 210 generates a custom front page 218 from a user 

20 template and the live data stored in shared memory 212. 

Although not shown, custom pages other than the front page can 
be generated, in a similar fashion. Using user templates and a 
shared memory for the live data, page server 104 can quickly 
build custom pages in response to a user request. Where the 

25 user template is cached, the page can be generated entirely 
within page server 104 . 

Shared memory 212 is organized as a set of memory 
mapped files. With memory mapped files, the operating system 
maintains the data in permanent storage;- but permanently 

30 caches the files in shared memory 212. - This allows for quick 
recovery should a page server crash, since all of the shared 
memory can simply be reloaded from the permanent storage. 
This is a great feature from a user convenience standpoint, 
since the user will never be faced with a situation where they 

35 have to wait for a server to rebuild a page for them by 

querying the various data providing servers, such as sports 
server 230, stock server 232 and news server 234. As should 
be apparent from this description and FIG. 2, page generator 
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210 can generate custom front page 218 much more quickly using 
shared memory 212 as compared with using servers 230 , 232, 234 
and page template 202, One reason for this is that the time 
it takes to retrieve data from shared memory 212 does not 
5 appreciably increase relative to the bandwidth delay time when 
more data is retrieved. For example, if stock server 232 were 
queried for each individual stock quote, a page with fifty 
stock quotes might take ten times as long to generate as a 
page with five stock quotes . 

10 One aspect of the present invention is the 

realization that every piece of information a person can 
request on a page is storable in a shared memory closely 
coupled to a page generator. For example, page server 104 
shown in FIG. 2 can accommodate 65,000 different symbols for 

15 which quotes are provided. In one embodiment, all of the 

stock information for all 65,000 symbols is stored in a 13 to 
14 megabytes section of the shared memory. Where shared 
memory 212 is a 64MB or 128MB memory, this leaves sufficient 
room for other data, such as news headlines, sport scores, and 

20 memory used by the operating system for each process running 
on page server 104. In some embodiments, shared memory 212 is 
large enough to also accommodate more than just news 
headlines. For example, news summaries (as described further 
in connection with FIG. 5) can be stored in shared memory 212 

25 for quick access. 

As shown in FIG. 2, the user's front page template 
202 does not need to be generated each time, but rather is 
stored in cache 214. In a preferred embodiment, user 
templates are stored in cache 214 for. long enough to be 

30 reused. Some users might choose to access their front page 
only infrequently, while others might choose to access their 
front page hourly. Since the pages are customized and 
dynamic, the user would see different information each time, 
but the same user template would be used each time. Of 

35 course, when the user edits his or her template, any cached 
copy of a user template is flushed, A garbage-collection 
process may also flush the cache of user pages which have been 
inactive for several days. In one implementation, cache 214 
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would accommodate 60,000 to 70,000 user templates. Where a 
particular page server is assigned on a random round robin 
basis, multiple page servers may cache their own copy of a 
given user template, but where a user is directed always to a 
5 particular server (except in the case where the particular 
server fails and a secondary server is used) , that page server 
will be the only one which needs to cache that users user 
template. Even where the round robin name server scheme is 
used, some browsers may cache IP addresses, even longer than 

10 the specified "time to live" variable associated with the IP 
address, in order to save the time required to obtain an IP 
address each time. With such a browser, the user is 
effectively directed to the same page server each time and the 
server side of the page serving system does not need to direct 

15 users to particular page servers. With newer browsers, 
however, the "time to live" variable is honored and new 
requests are made for IP addresses after the "time to live" 
has expired. In these cases, if the assignment of a user to a 
single page server is desired, name server 108 (see FIG. 1) 

20 will use the user name from the provided cookie or the user's 
IP address to assign a page server based on a hash of the user 
name or IP address . 

FIG. 3 is an illustration of global user template 
204. Global user template 204 is an HTML (HyperText Markup 

25 Language) document with additional tags as placeholders for 
live data. Several placeholders 302 are shown in FIG. 3. 

FIG. 4 is an illustration of user template 202 as 
might be generated from global user template 204 (see Fig. 3) 
and a user configuration record 206.... A . full listing of user 

3 0 template 202 is included herewith in Appendix A. User 

template 202 is determined by the user configuration and is 
independent of the live data, therefore it can be cached 
without needing to be updated, unless the user chooses to edit 
the configuration information. Preferably, the user templates 

35 are cached rather than the user configuration, to save a step 
and reduce the time to respond to a request for the page. 
Caching is more effective where the typical user makes several 
requests in a short time span and then doesn't make any 
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requests for a long period of time. 

Essentially, user template 202 contains the 
information about the user which. does not change until the 
user changes his or her preferences. Of course, the system 
5 operator could choose to make changes to how the system 

operates, thus requiring changes to the user preferences and 
user templates. User template 202 is shown comprising 
internal variables such as a time zone and demographic 
information. The demographic information, on the second line 

10 in FIG. 4 is used for selection of an advertisement which will 
be part of the custom page. In this example, the 
advertisement is targeted by the demographic information in 
the user template " :M, 85, 95035, T, *" indicating that a suitable 
ad should be targeted to a male user, age 85, located in zip 

15 code 95035, etc. As shown, the portfolio section contains 
selected stock symbols, the scoreboard section contains 
selected team symbols, and the weather section contains 
selected weather cities/zip codes . 

The selections of stock quote symbols, team scores, 

20 and weather cities are set by the user. In a preferred 

embodiment, intelligent defaults are selected by the system 
prior to user selection, so that users unfamiliar with the 
customization process will nonetheless be able to view non 
empty custom pages. This is described in further detail below 

25 in connection with FIG. 6. 

FIG. 5 is an illustration of a user front page 218 
returned by page server 104. User front page 218 as shown in 
FIG. 5 includes many elements, some of which are described 
here in further detail. User front -page. 218 is built 

30 according to a user template and live data. The user template 
specifies, for example which quotes are shown in the portfolio 
module, which cities are displayed in the weather module, etc. 

Each of the modules 504 can be customized by a user and moved 
about front page 218. The modules 504 are also reusable, in 

35 that any customized module which appears on multiple pages can 
be edited from any one of those pages and the edits will be 
reflected on each of the pages. Other custom pages for the 
user can be viewed by selecting one of the page buttons 502 
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appearing below the header. Other pages and utilities can be 
selected using the buttons 508 which are part of the header. 

In addition to all of the live date shown in FIG. 5 
being stored in the shared memory/ summaries from each of the . 
5 major news topics can also be stored in the shared memory and 
viewed by pressing on the news topic header, such as news 
topic header 506. As should be noted, the page generator can 
also intelligently display dates 510 customized for a 
particular user, using a time zone variable in the user 

10 template. This time zone variable is shown as the first line 
in user template 202 in FIG. 4. In addition to being able to 
modify each of the modules, in many cases the order of 
appearance of the modules is customizable. For example, the 
order of the various sections of user template 202 shown in 

15 FIG. 4 is not fixed. 

The preference editing process can be initiated by . 
the user pressing the appropriate edit button 512 . As 
explained above, once the editing process is complete, the 
user template is flushed from the cache and regenerated. 

20 Since each of the news stories is essentially a static page 
linked to a headline shown in the news section, these can 
simply be linked to static pages on a news server. 

Referring now to FIG. 6, an illustration of 
intelligent defaulting for populating a user template, and 

25 consequently a user summary page. As part of a registration 
process, a user indicates, among other things, his or her zip 
code . This zip code is used to locate an approximate 
longitude and latitude for the user using a zip code lookup 
table 602. This allows the user's location to be located on a 

30 map 604. Map 604 provides city boundaries and, with team 

location table 606, also provides locations for various sports 
teams which can be selected in a sports module. In selecting 
a default predetermined number of cities and sports teams for 
inclusion as initial selections for a particular user, a 

3 5 circle is drawn around the user and increased in diameter 

until the circle envelopes a suitable predetermined number of 
cities and sports teams. In this way, each user is guaranteed 
a default number of nearby teams and cities for sports and 
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weather, respectively. While this assumes that the user is 
interested in only the teams nearest the user, the system can 
be arranged to provide intelligent defaults where geographic 
anomalies are known to exist . Geographic anomalies occur in 
5 communities which have more loyalty to distant teams than 
nearby teams, such as might occur when the distant team is 
much better than the nearby team or when the nearby team 
recently moved to a distant location. In any case, the user 
is allowed customize his or her pages beginning with the 
10 intelligent defaults selected. 

Other intelligent defaults can be provided in other 
contexts. For example, the header of user front page 218 
includes a button 508 labelled "myweb" which, when pressed, 

* 

would lead the user to a custom listing of web sites. The 
15 initial defaults for that custom listing of web sites might be 
generated based on the keywords of interest to that user or 
based on the news topics, sports teams or weather cities 
selected by the user. 

The above description is illustrative and not 
20 restrictive. Many variations of the invention will become 
apparent to those of skill in the art upon review of this 
disclosure. The scope of the invention should, therefore, be 
determined not with reference to the above description, but 
instead should be determined with reference to the appended 
25 claims along with their full scope of equivalents. 
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Appendix A. Listing of a User Template 

<! — timezone: -8, PT 0 — > 
<!— ad:M,85, 95035, T,* 792 ~ > 
5 <! — 

port folio: Quotes ,pf_l, 1, A DJI, A NYA, ^IXIC, A SPX, ~XAX, YHOO, NSCP, IOM, NSCP, YHOO 
2836 — > 
<! — 

scoreboard : NCAAFSSC, NHL SAN , MLS SAN , NC AAFS S S , ALOAK , NBAGSW, NFLOAK, NCAAFCCD, NF 
10 LSFO,NLSFO 3803 ~> 

<!-- weather: f, 30901, uk_londo, 94601, 95101 4368 — > 
<! — 

mode — bar : "FRONTPAGE", . hier=News+Summary%3aEdit & . done=http : / /my . yahoo . com/ 
news /summary. html? v 4538 — > 
15 <! — summary2 : 3, rt, rw, z0000,ralb, re, vf 4597 — > 
<! — motd: us_motn.html 4 696 — > 
<html> 
<head> 

<title>My Yahoo! news summary for ash802</title> 
20 </head> 
<body> 

<center> 

<map name="top"xarea shape=rect coords= 3 "0, 0, 45/ 66" 
25 href =" /news /summary. html?v"xarea shape=rect coords="45, 0, 90, 66" 

href="/internet/directory.html?v"xarea shape=rect coords="90, 0, 135,66" 

href =" /contact s/whitejpages ,html?v"><area shape=rect coords="135, 0, 34 6, 66" 

href="/?myHome ,, xarea shape=rect coords="346, 0, 389, 66" 

href="/help/news/summary.html"xarea shape=rect coords="389, 0, 431, 66" 
30 href ="http: //edit. my. yahoo. com/conf ig/eval_profile"xarea shape=rect 

coords»"431, 0, 477, 66" href="http: //edit .my .yahoo. com/conf ig/toffly"> 

</map> 

<centerxa href= 3 "/bin/top_menu"ximg border=0 height=62 width«477 ismap 
usemap="#top" src=>"http : //www. yahoo. com/images/my/banner /newsl .gif" 
35 alt="My Yahoo ! "></a></center> 

<P> 

<centerxform action«"http: / /search. my. yahoo. com/search/my "> <font 
size~"-2">[ <a 

40 href ="http: //edit .my. yahoo. com/conf ig/set_attr?attr=sloc&value=b& ,done=*htt 
p: //my. yahoo. com/news /summary. html?v">raove to bottom</a> ] </fontxinput 
size=25 name=«p> <font size="-l">  <input type=submit 
value=Searchxinput type=hidden name=n value«"25">   <a 
href ="http: / /search. my. yahoo. com/search/my/options">Options</ax/fontx/fo 

45 rmx/centerxp> 



WO 98/57276 PCT/US98/09782 

13 

.**■*■ 

<center> 

<table border=0 cellspacing=0 cellpadding=2> 
<tr> 

<td align^centerxfont 
5 color«"#000000"><b>Sections:</b>  </font></td> 
<td align=center bgcolor~"#dcdcdc"xfont 
co!or» n #000000"xb>Front Page</bx/fontx/td> 
<td>  | </td> 

<td align="center><a href ~ n /news /business /summary. html ?v">Business</ax/td> 
10 <td>  I  </td> 
<td align^centerxa 

href /news/port folio_summary . html?v">Portfolios</ax/td> 
<td>  | </td> 
<td align=centerxa 
15 href=" /news /entertainment /summary .html? v">Entertainment</ax/td> 
<td>  I   </td> 

<td align=centerXa href=Vnews/sports/summary . html?v n >Sports</ax/td> 
<td>Snbsp; | </td> 
<td align=center><a 
20 href s ="/news/technology/suramary.html?v">Technology</ax/td> 
</tr> 
</table> 
</center> 
</center> 

25 <table border=l cellpadding=4 cellspacing=0 width="100%"> 
<trxtd align=center valign=top width="l%"> 
<a 

href^'http: //edit .my. yahoo . com/conf ig/eval_lef t?mode s =lef t_nsum& . done=http% 
3a%2f %2fmy%2eyahoo%2ecom%2fnews%2fsummary%2ehtml%3fv"ximg border=0 

30 src~"http://www. yahoo, com/images /my/left .gif" alt="edit left"x/a> 
<table border=0 cellpadding=l cellspacing=0 width=»"100%"> 
<tr bgcolor="#dcdcdc"xtd colspan=4 width=* M 100% "xtable border«0 
cellpadding=2 cellspacing»0 width~"100%"xtrxtd width="100% "xbxfont 
size«"+l">P<font size= ,r +0">0RTFOLIOS</fontx/fontx/bx/tdxtd 

35 align^rightxa 

href="http: //edit .my . yahoo . com/conf ig/eval_quotes? .done«http: //my . yahoo, co 
m/news/summary.html?v"ximg align=absraiddle border=0 height=13 width=25 
src="http : //www . yahoo . com/images /my/personalize . gif ,r 
alt="edit"x/ax/tdx/trx/tablex/tdx/tr> 

40 <trxtd align-center colspan~4xform method~get 

action="http: //quote, yahoo. com/quotes"xf ont size s = l '-l"xinput type«text 
size=10 name«symbols><input type=subroit value="Get Quotes"xbrxfont 
size="O n >quotes delayed 20 minutes - <a 

href«"/fin_disclaimer .html">disclaimer</axbr>click on symbol for detailed 
45 quote + news<br><b>*</b> indicates new news during last 
24hrs<fontx/formX/tdx/trX/table> 
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<hr size=0><table border=0 cellpadding^l cellspacing=0 width= M 100%"> 
<tr bgcolor="#dcdcdc n xtd colspan=5 width-" 100% "xtable border=0 
cellpadding=2 cellspacing=0 width= M 100% "xtrxtd width="100% n Xa 
href =*"/sum/?http: //sports. yahoo. com/ "xbxfont size= s " + l n >S<f ont 
5 si2e= M +0">COREBOARD</fontx/fontx/bx/ax/tdxtd align-rightxa 

href = n http : //edit .my . yahoo . com/conf ig/set_sports? . done=*http : //my . yahoo . com 
/news /summary. html?v"ximg align=absmiddle border=0 height=13 width=25 
src="http: / /www. yahoo . com/images /my/personalize . gif " 
alt="edit "></ax/tdx/trx/tablex/tdx/tr> 

10 

<hr size=0xtable border=0 cellpadding~2 cellspacing=0 width="100% n > 
<tr bgcolor="#dcdcdc"xtd colspan=3 width=" 100%"xtable border=0 
cellpadding=2 cellspacing=0 width="100% "xtrxtd width="100%"xa 
hre f =" /my / ?ht tp : / / weather . yahoo . com/ " xbxfont si ze= " + 1 " >W< font 

15 size= ,f +0">EATHER</fontx/fontx/bx/aX/tdxtd align=rightxa 

href <="http : //edit .my . yahoo . com/conf ig/set_wni? .done=http: //my . yahoo . com/ne 
ws/summary .html?v"ximg align=absmiddle border=0 height=13 width=25 
src="http : //www . yahoo. com/ images /my /personalize . gif" 
alt= ,, edit"x/a></tdx/trx/tablex/tdx/tr> 

20 <trxtd align=center colspan=3xfont size=0>click on city for extended 
forecast</fontx/tdx/tr> 
</table> 

<hr size=0> 
25 <px/td> 

<td align^center valign=top width="100%"> 

<table border=l cellpadding=2 cellspacing=*0 width= f, 100%"> 
</table> 

30 

</tdx/tr> 
</table> 

3 5 <center> 

<table border=l cellpadding=2 cellspacing=0 width="100%"> 

</table> 
</center> 

40 

<p> 
<hr> 

<center> 

<table border=0 cellpadding=0 cellspacing=>0 width="100%"> 
45 <tr> 

<td align=left valign=top><table border=0 cellpadding=0 cellspacing=0> 
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Kr a 

<trxtd align«left valign»bottom><a href=Vmy/?http: //www. yahoo, com/" ximg 
border=0 height=47 width=47 src="http : //ww. yahoo . com/ images /my /yahoo, gif" 
alt= n Yahoo! "x/ax/td> 
<td>   </td> 
5 <td align=left valign=bottom width="100%"xf ont size«"-l"xi>Copyright 
ficopy; 1994-1997 Yahoo! Inc. All rights reserved. </ixbr>Portions 
copyright © 1997 Reuters Ltd. All rights reserved. <br> 
Portions copyright Scopy; 1997 SportsTicker Enterprises LP. All rights 
reserved. <br> 

10 Portions copyright © 1997 Weathernews Inc. All rights reserved. <br> 
Portions copyright © 1997 Business Wire. All rights reserved. <br> 
Portions copyright © 1997 PR Newswire. All rights reserved. <br> 
Questions, comments, or suggestions? Send us <a 

href=*"http: / /my. yahoo, com/ feedback. html" >f eedback</a> . </fontx/td> 
15 </tr> 
</table> 
</td> 

<td>    </td> 

<td align=rightxa href="/bin/logout_menu"ximg border«0 height=68 
20 width=100 ismap usemap= "# logout n 

src="http: //www. yahoo.com/images/my/logout . gif " alt="Change 
User"x/ax/td> - . 

</tr> 
</table> 
' 25 </center> 

<map name=logout> 

<area coords^ M 0, 0, 50, 68" href ="/my/?http : //www. yahoo, com/ "> 
<area coords="51, 0, 100, 68" 

href« w http: //edit .my. yahoo . com/config/login?logout=l n > 
3 0 </map> 



</body> 
</html> 
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Appendix B. Listing of a User Page 



<html> 
<head> 

5 <title>My Yahoo! news summary for ash802</title> 
</head> 
<body> 



<center> 

10 <map name="top"Xarea shape=rect coords= 3 "0, 0, 45, 66" 

hr ef=Vnews /summary, html ?v"Xarea shape=rect coords=»"45, 0, 90, 66" 
href =" /internet/directory. html?v"Xarea shape=rect coords«"90, 0, 135, 66" 
hr ef »"/cont act s/white_pages . html ?v"><area shape=rect coords»"135, 0, 346, 66" 
href="/?myHome"xarea shape»rect coords="346, 0, 389, 66" 

15 hre f= rt /help/news /summary. html "xarea shape«rect coords="389, 0, 431, 66" 
href="http : //edit -my . yahoo . com/conf ig/eval_prof ile"xarea shape«rect 
coords="431,0, 477, 66" href ="http: //edit .my . yahoo. com/conf ig/toffly"> 
</map> 

<canterxa href /bin/ top_menu"ximg border^O height=62 width-477 ismap 
20 usemap="#top" src^'http: //www. yahoo, com/ images /my/banner /news 1 .gif" alt="My 
Yahoo! M x/ax/center> 

<font size»"-5"Xpx/font><! — SpaceID=0 noad — > 

<font size="-5 n xpx/font> 
25 <p> 

<centerxform action="http: //search, my .yahoo .com/search/my"> <font size="-2">[ <a 
href =>"http:7/edit .my . yahoo . com/conf ig/set_attr?attr=sloc&value~b& . done=http : //my . y 
ahoo. com/ news /summary, html? v">move to bottom</a> ] </fontxinput size=25 name=p> 
<font size= M -l">4nbsp; <input type-submit value^Searchxinput type-hidden name=n 
30 value="25"> Snbsp; <a href «"http: //search. my .yahoo. com/search/my /options" 
>0ptions</ax/fontx/formx/centerXp> 
<center> 

<table border=0 cellspacing=»0 cellpadding= : 2> 
<tr> 

35 <td align»centerxfont colors" #000000 "xb>Sections:</b>  </fontx/td> 
<td align=center bgcolor* 3 "#dcdcdc">< font 
color="#000000"><b>Front Page</bX/fontx/td> 
<td>  I finbsp; </td> 

<td align-centerxa href«" /news /business /summary. html ?v M >Business</ax/td> 
40 <to>  I inbsp;</td> 

<td align-centerxa href ="/news /port folio_summary.html?v">Portfolios</ax/td> 

<td>  l </td> 
<td align«center><a 

href«" /news /entertainment /summary, html ?v">Entertainment</a></td> 
45 <td>  |  </td> 

<td align«center><a href= "/news /sports /summary .html?v">Sports</a></td> 

<td>  I  </td> 

<td align-centerxa href »"/ news /techno logy /summary . html?v">Technology</aX/td> 
</tr> 
50 </table> 
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</center> 
</center> 

5 <table border=l cellpadding=4 cellspacing-0 widths" 10 0% M > 
<tr><td align=center valign=top widths " 1 % "> 
<a 

href=» n http : / /edit .my . yahoo . com/conf ig/eval_lef t?mode~lef t_nsum&. done=*http%3a%2f %2f 
my%2eyahoo%2ecom%2fnews%2fsumniary%2ehtiia%3fv"ximg border=0 
10 src«"http://www. yahoo. com/images /my/left.gif" alt«"edit left M x/a> 
<table border=0 cellpadding=l cellspacing=0 width«"100%"> 

<tr bgcolor~ n #dcdcdc"xtd colspan=4 width«"100% w xtable border=0 cellpadding=2 

cellspacing=0 width= H 100%"xtrxtd width-"100% "xbxf ont size«"+l w >P<font 

size="+0">ORTFOLIOS</fontx/fontx/bx/tdxtd align=rightxa 
15 href »"http : / /edit .my . yahoo . com/conf ig/eval_quotes? . done*»http : //my . yahoo . com/news /s 

ummary.html?v f, ximg align^absmiddle border«0 height=13 width=25 

src^'http : //www . yahoo . com/images /my/personalize . gif " 

alt»"edit"x/ax/tdx/trx/tablex/tdx/tr> 

<tr><td valign=top widths "10%"Xnobr><a 
2 0 href="http : / /edit .my . yahoo . com/conf ig/set_portf_expand?port«Quotes&expand«0& . done=» 

http: //my. yahoo .com/news /summary. html ?v"ximg align=absmiddle border»0 heighten 

width=ll src« "http: //www. yahoo . com/images/my/arrowdown. gif " 

alt»"edit"x/ax/tdxtd valign^top widths" 30% "xnobrxbxa 

href="http: / /quot e. yahoo. com/por t f ol io ? views key=pf_l">Quotes</aX/bx/nobrx/tdxt 
25 d width="30%"x/tdxtd width«"30%"xbigx/tdx/tr> 

<trxtd align=left valign=top width="10% n xnobrxfont size=» M - 

l'^  <br>  <br>  <br> <br>snbsp;<br>*<br>*<br>*<br>*<br>*<brx/fo 
ntx/nobrx/tdxtd valign~top width=»"30%"Xnobrxfont size="-l"xa 
href«"http: / /quote, yahoo. com/quotes ?SYMBOLS» A DJISdetailed='t n >DJIA</axbr> 

3 0 <a href="http: / /quote . yahoo. com/ quotes ?SYMBOLS= A NYA&detailed=t">NYSE</axbr> 
<a href ="http: //quote. yahoo. com/ quotes ?SYMBOLS~ A IXIC&detailed=t">NASDAQ</axbr> 
<a href -"http: //quote. yahoo. com/quotes?SYMBOLS=* A SPX&detailed»t">S&P 500</aXbr> 
<a href="http: //quote. yahoo, com/quotes?SYMBOLS= A XAX£detailed=t">AMEX</axbr> 
<a href="http: //quote, yahoo, com/ quotes?SYMBOLS«YHOO&detailed»t">YHOO</axbr> 

35 <a href»"http: //quote. yahoo. com/quotes ?SYMBOLS=NSCP&detailed«t">NSCP</axbr> 
<a href- M http: //quote. yahoo. com/quotes ?SYMBOLS«IOM&detailed=t">IOM</axbr> 
<a href="http: //quote. yahoo. com/ quotes ?SYMBOLS=NSCP&detailed«t">NSCP</axbr> 
<a href ="http : //quote . yahoo . com/quotes ?SYMBOLS-YHCX)&detailed«t">YHCX)</a><br> 
</fontx/nobr></tdxtd align«right valign=top width- "30 ft "xnobrx font size-"- 

40 l M >7312.15<br>442.36<br>1384.9Kbr>845.48<br>609.02<br>32 l/2<br>29 l/4<br>19 
l/4<br>29 l/4<br>32 l/2<brx/font></nobr></tdxtd align=»right valign«top 
width«"30%"><nobrxfont size= M -l"xf ont size="-l" 
color« l, #007f00 ,, >+22.75</f ontxbrxfont size-"-!" 

color="#007f 00">+0 . 82</f ontxbrxfont size-"-l" color« ,, #7f 0000">- 
45 19. 88</f ontxbrxfont size="-l" color="#7f0000">-0. 88</f ontxbrxfont size="-l" 

color="#007f00">+1.85</fontxbrxfont size°"-l" color="#7f 0000">- 

5/8</font><brXfont size»"-l" color«"#7f 0000">-5/8</fontxbrxfont size-"-!" 

color- ,, #007f00">+l/2</f ontxbrxfont size=»"-l" color~"#7f 0000">- 

5/8</fontxbrxfont size« M -l" color="&7f 0000">- 
50 5/8</font><brx/fontx/nobrx/tdx/tr> 

<trxtd align=center colspan~4xf orra method=get 
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action="http: //quo te.yahoo.com/quot es M x font size- f, -l"xinput type-text size-10 
name«symbolsxinput type=submit value="Get Quotes "xbrxfont 3i2e» ,, 0">quotes 
delayed 20 minutes - <a href="/f in_di sclaimer.html ">disclaimer< /axbr>click on 
symbol for detailed quote + news<brxb>*</b> indicates new news during last 
5 24hrs<fontx/formx/tdx/trx/table> 

<hr size=0xtable border=0 cellpadding=l cellspacing-0 width«"100%"> 

<tr bgcolor="#dcdcdc"xtd colspan»5 width"" 100% "xtable border=»0 cellpadding«2 

cellspacing=0 width="100%"xtrxtd width=>"100%"xa 

href =" /sum/ ?http: //sports. yahoo. com/"xbxfont size=*"+l">S<font 

10 size«"+0">COREB0ARD</fontx/fontx/bx/ax/tdxtd align=right><a 

href-"http : //edit .my. yahoo, com/config /set_sports? . done«http : / /my . yahoo . com/news/su 
mmary.html?v"ximg align-absmiddle border»0 height=13 width=25 
src="http: //www. yahoo. com/ images /my /per sonalize.gif" 
alt="edit"x/ax/tdx/tr></tablex/tdx/tr> 

15 <trxtd colspan«5xbxfont size= ,, -l">TODAY</fontx/bx/tdx/tr> 
<tr><td valign=topxfont size^lxa 

href ="http: //sports. yahoo. com/al/">AL</a></fontx/tdxtd valign=topxf ont size— 
l>Detroit<brxb>Oakland</bx/fontx/tdxtd align=right valign=topxfont size— 
l>8<br>9</f ontx/tdxtd ' valign=top> </tdxtd valign-topxfont size— lxa 
20 href= M http: //sports. yahoo. com/al/rcps/970603/detoak.html">F</ax/fontx/tdx/tr> 
<trxtd valign^topxfont size— lxa 

href= M http: //sports .yahoo. com/nl/">NL</ax/fontx/tdXtd valign=topxfont size— 
l>San Francisco<br><b>Florida</bx/fontx/tdxtd align=right valign-topxfont 
size— l>9<br>K/fontx/tdxtd valign=top>  </tdxtd valign«topxfont size— 
25 lxa 

href «"http: //sports. yahoo.com/nl/rcps/970603/sfof la. html w >F</ax/fontx/tdx/tr> 
<trXtd col-span=5xbXfont size="-l">YESTERDAY</f ontx/bx/tdx/tr> 
<tr><td valign=topxfont size=»-l><a 

href= M http: //sports. yahoo. com/ai/">AL</aX/fontx/tdXtd valign-topxfont size— 
3 0 l>Detroit<br><b>Oakland</bx/fontx/tdxtd align=right valign«topxfont size— 
l>B<br>7</fontx/tdxtd valign~top>  </tdxtd valign=«topxf ont size— lxa 
href ="http: //sports, yahoo.com/al/rcps/970602/detoak. html M >F</ax/fontx/tdX/tr> 

<trxtd valign=topxfont size°-l><a 

href-"http: //sports. yahoo, com/nl/">NL</a></fontx/tdxtd valign«topxfont size— 
35 l>San Francisco<brxb>Florida</bx/fontx/tdxtd align«right valign-topxfont 
size— l>2<br>4</fontx/tdxtd valign=top> </tdxtd valign-topxfont size— 
lxa 

href="http: //sports, yahoo.com/nl/rcps/970602/sf of la. html ">F</a></ font ></td></tr> 
</table> 

40 

<hr size~0xtable border=0 cellpadding=2 cellspacing«0 width« M 100%"> 

<tr bgcolor-"#dcdcdc"xtd colspan-3 width=»" 100% ">< table border-0 cellpadding-2 

cellspacing=0 width="100%"xtrxtd width- " 100 %"><a 

href«"/my/?http: //weather. yahoo. com/ "xbxfont size*"+l ■■>«»< font 
4.5 3ize-"+0 M >EATHER</font></font></bx/a></td><td align-rightxa 

href «"http : / /edit . my . yahoo . com/conf ig/set_wni? . done=http : / /my . yahoo . com/news/summa 

ry.html?v M ximg align-absmiddle border«0 height»13 width«25 

src-"http: //www. yahoo, com/ images/my /personal ize. gif " 

alt«"edit M x/ax/tdx/tr></tablex/tdx/tr> 
50 <trxtdxa href « M http: //weather. yahoo. com/forecast/Augusta - GA_US - f.html ,l xfont 

size="-l">Augusta, GA</f ontx/ax/tdxtd align-rightxfont size="-l">63. . .78 
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F</font></tdxtd align=rightxfont size~"-l"xiiug height»24 width=»32 
src="h£tp: //www. yahoo.com/images/my/wni/87.gif" alt- n Showers"x/f ont></tdx/tr> 
<trxtd><a href«"http : / /weather . yahoo . com/ fore cast/ London_UK_f . html "xf ont size-"- 
l">London, DK</fontx/ax/tdxtd align«rightxf ont size-"-l">50. . .73 
5 F</fontx/tdxtd align-rightxfont size«"-l"ximg height=24 width«32 

src="http: //www. yahoo. com/ images/my/wni/87 .gif " alt« ,, Showers"x/f ontx/tdx/tr> 
<trxtdxa href-^http: //weather . yahoo, com/ forecast /Oakland_CA_US_f. html " x font 
size«"-l ,, >Oakland, CA</fontx/ax/td><td align=rightxfont size«"-l">59 . . . 70 
F</fontx/tdxtd align=rightxfont size="-l t, ximg height=24 width-32 
10 src-"http: //www. yahoo.com/images/my/wni/66. gif" alt«" Partly 
Cloudy"x/fontx/tdx/tr> 

<trxtd><a href»"http: / /weather . yahoo. com/ forecast /San_Jose_CA_US_f .html" x font 
size="-l">San Jose, CA</fontx/ax/tdxtd align-rightxfont size="-l">54 . . . 75 
F</fontx/tdxtd align-rightxfont size="-l"ximg height-24 width«32 
15 src="http: //www. yahoo.com/images/my/wni/82. gif" alt="Rain"x/fontx/tdx/tr> 
<trxtd align«center colspan=3xfont size-0>click on city for extended 
forecast</fontx/tdx/tr> 
</table> 

20 <hr size=0> 
<px/td> 

<td align=center valign»top width«"100%"> 
<center> 

<table border~l cellpadding=4 cellspacing=0 width="100%"> 
25 <tr> 

<td bgcolor="#OOOOOO n > 

<table border-0 cellpadding=0 cellspacing-0 width-" 1 00 %"xtr> 
<td align=left valign«bottom><font color=«"#ff f f f f n 
s i z e« "+ 1 " xnobrxb>F< /bx /nobrx / font ><f ont 
30 color="#f fffff "><bxnobr>RONT</nobr>  <nobr>PAGE</nobr></b> - Jun 3 
7 : 40pm</f ont></td> 
<td align* right ><a 

href«"http: //edit . my. yahoo, com/ conf ig/edit_news ? . hier~News+Summary%3aEdit& .done=ht 

tp: //my. yahoo. com/news /summary. html ?v"ximg align=right border«0 height«15 
35 width=66 vspace«2 src-^http:/ /www. yahoo. com/ images /my/ edit_topics.gif" alt«"edit 

topics "x/ax/tdx/tr> 

</table> 

</td> 

</tr> 
40 </table> 

</center> 

<table border-1 cellpadding«2 cellspacing»0 width="100%"> 

<trxtd bgcolor" n #dcdcdc" colspan»2xa hre f»" /news /top_stories. html ?v"xbxf ont 
45 size="+l">B</font>reaking News</bx/a>  <i>Jun 3 5:03pm</ix/tdx/tr> 
<trxtd colspan-2xul> 

<lixa href» n http: //www. yahoo.com/headlines/970603/news/stories/bombing_61.html" 
> Judge Moves to Avoid McVeigh lynching 1 </a> 
<lixa href- 

50 "http: / /www. yahoo, com/headlines/ 970603/news/stories/bombingappeals_l . html ">McVeigh 
's Expected Appeals May Last Years</a> 
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<lixa 

href =»"http : //www . yahoo . com/headlines / 970 603 /news/stories/bombingpenalty_l . html ">Ex 

perts: Plea for Mercy is McVeigh 's Best Hope</a> 

</ulx/tdx/tr> 

5 <tr><td bgcolor=»"#dcdcdc" colspan=2xa href /news/world. html ?v"xbx font 
size~"+l">W</font>orld</bx/a>  <i>Jun 3 2:09pm</ix/tdx/tr> 
<trxtd colspan=*2xul> 
<lixa 

href="http: //www. yahoo. com/ headlines/ 97 0603 /international /stories /canada_6. html" >C 
10 anadian Liberals Face Thorny Issues</a> 
<lixa 

href ="http: / /www. yahoo. com/headlines/ 97 0603 /international/stories/nato_10. html" >U. 

S. Advocates Ready for NATO Expansion Fight</a> 

<lixa 

15 href="http: / /www. yahoo. com/headlines/ 97060 3 /international/ stories / leone_ll.html ">U 
.S. Ferries More Foreigners from Sierra Leone</a> 
</ulx/tdx/tr> 

<trxtd bgcolor= n #dcdcdc" colspan«2xa 

href«"http: //biz. yahoo.com/news/z0000. html"xbxf ont size="+l">U</font>.S. Stock 
20 News and Report</bx/a>  <ix/ix/tdx/tr> 
<trXtd colspan=*2Xul> 

<lixa href= M http: //biz. yahoo. com/ finance/ 97/0 6/03 /crdm_y001_l .html ">Cardima Inc 
IFO range reduced - underwriter</a> 

<lixa href="http: //biz. yahoo. com/ finance/ 97/0 6/03/ luk_wtsc_l.html">AMEX to trade 
25 Leucadia, West TeleServices options</a> 

<lixa href- rt http: //biz. yahoo. com/f inance/ 97/ 06/03/ acv_acva_l .html ">CBOE to trade 

options on Alberto-Culver Class A</a> 

</ulx/tdx/tr> 

<trxtd bgcolor-" tdcdcdc" colspan=2xa href -"/news /sports /mlb. html ?v"xbxf ont 
30 size="+l">M</font>ajor League Baseball</bx/a>  <i>Jun 3 5 : 15pm</ix/tdx/tr> 
<trxtd colspan«2><ul> 

<lixa href="http: //sports . yahoo. com/mlb/lgns/ 970603 /draftlist .html f, >l 997 baseball 
free agent draft first round selections</a> 

<lixa href ="http : //sports . yahoo . com/nl/lgns/970603/nlstars . html">Mike Piazza 
35 leads balloting in NL All-star voting</a> 

<lixa href-"http: / /sports. yahoo. com/nl/lgns/ 97 0603 /nlvotes. html ">National League 

All-Star voting results</a> 

</ulx/tdx/tr> 

<tr><td bgcolor-" fcdcdcdc" colspan-2xa 
40 href="/news/entertainment/top - stories.html?v ,, xbxfont 

size- ,, +l M >E</font>ntertainment Top Stories</bX/a>  <i>Jun 3 
6 : 35pm</ix/tdx/tr> 
<trxtd colspan-2Xul> 

<lixa href «"http: / /www. yahoo.com/headlines/970603 
45 /entertainment/summary^.htmliheadline^l^^linton Reflects on Music </a> 
<lixa href="http: //www. yahoo.com/headlines/970603 

/entertainment/summary_l.html#headline_2">Gifford: Marriage is Solid </a> 
<lixa href= M http: //www. yahoo.com/headlines/970603 

/entertainment/summary_l.html#headline_3 ,, >Rockabilly Legend Hospitalized </a> 

50 </ulx/tdx/tr> 

<trxtd bgcolor-" fldcdcdc" colspan-2xa 
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href ^Vnews /entertainment /movies, html ?v"xbxfont size="+l M >M</font>ovies + 
Film</bx/a>£nbsp; <i>Jun 3 10 : 13am</ix/tdx/tr> 
<tr><td colspan=»2><ul> 

<lixa href ="http: //www. yahoo.com/heacUines/970603/entertainment 
5 /stories/film^cage^l.html'^FEATURE: Nicolas Cage Asks, Where Are The Heroes?</a> 
<lixa href»"http: //ww. yahoo. com/headlines/ 97 0603 /entertainment 
/stories/f ilm_cas save tes_l .html ">Nick Cassavetes Updates Father's 1 Bookie '</a> 
<li><a href="http: //www. yahoo. com/headlines/ 97 060 3 /entertainment 
/stories/film_boxoffice_9. html Lost World 1 Props Up Slow Box Office</a> 
10 </ulx/tdx/tr> 
</table> 

</tdx/tr> 
</table> 

15 

<center> 

<table border** 1 cellpadding=2 cellspacing~0 width«' f 100% l, > 
<tr bgcolor~"#f0f8ff"> 

<td align»center colspari=2xtable border=0 cellpadding= 3 2 cellspacing^O 
2 0 widths" 100% "> 

<trxtd align-left width«"60%"Xfont size="-l"xb>TIP  </b> clicking on the I 
Yahoo! logo at the top will reload and update your default page. </fontx/tdxtd 
align«center width="28%" nowrapxfont size»"-l ,, ><a 

href="http : //bwguide. yahoo, com/bwguide/ start .html ">Yahoo ! BackWeb Channel - 
25 Guide</axbr><a href="http: //www. yahoo. com/docs /info/out reach/ ">Yahoo! Community 
Relations</ax/fontxbrXbrxfont size="-l"xa 

href ="/motn/?http: //local. yahoo. com/ local/ rt >Get Local</a> · <a 
href ~"/motn/?http: //my. yahoo. com/ ticker. html ">News Ticker</a> £#183; <a 
href«"/motn/?http: //fool. yahoo. com/fool ">Motley FooK/aX/f ontx/tdx/tr> 
30 </tablex/td> 
</tr> 
</table> 
</center> 

<P> 
35 <hr> 

<center> 

<table border-0 cellpadding~0 cellspacing=0 width="100%"> 
<tr> 

<td align»left valign«topxtable border=0 cellpadding»0 cellspacing«0> 
40 <trxtd align-left valign=bottomxa hre f»" /my Y?http: //www. yahoo. com/" ximg 
border=0 height=»47 width-47 src»"http: //www. yahoo. com/ images /my/ yahoo.gif" 
alt-" Yahoo ! "x/ax/td> 
<td>   </td> 

<td align«left valign=bottom width="100% ,, xfont size«"-l"xi>Copyright © 
45 1994-1997 Yahoo! Inc. All rights reserved. </ixbr>Portions copyright ficopy; 1997 
Reuters Ltd. All rights reserved. <br> 

Portions copyright © 1997 SportsTicker Enterprises LP. All rights 
reserved. <br> 

Portions copyright © 1997 Weathernews Inc. All rights reserved. <br> 
50 Portions copyright © 1997 Business Wire. All rights reserved. <br> 
Portions copyright © 1997 PR Newswire. All rights reserved. <br> 
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Questions, comments, or suggestions? Send us <a 

href="http: //my. yahoo.com/feedback. html ">feedback</a>.</fontx/td> 
</tr> 
</table> 
5 </td> 

<td>   </td> 

<td align-rightxa href=*"/bin/logout_menu"ximg border-0 height=68 width=*100 ismap 
us emap=»"# logout" src="http: //www. yahoo. com/ images /my /logout .gif" alt="Change 
User"x/ax/td> 
10 </tr> 
</table> 
</center> 
<map name=logout> 

<area coords«"0, 0, 50, 68" href="/my/?http: //www. yahoo. com/ w > 
15 <area coords="51, 0, 100, 68" href ="http: //edit. my. yahoo.com/conf ig/login?logout-l"> 
</map> 

</body> 
</html> 
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WHAT IS CLAIMED 15 : 

1 . A server system for serving a customized 
information page to a user at a browser on request , 

5 comprising: 

a database of user configurations; 
means for obtaining information from the user 
referencing a record in the database of user configurations, 
the record being a record for the user; 
10 means for generating a template based on the record 

for the user; 

a plurality of user processes, one process per user 
accessing the server system; 

a shared memory; 
15 a data structure within the shared memory for 

storing the dynamic information needed to generate the 
customized information page; and 

response means for responding to a request with an 
information page containing dynamic information from the data 
20 structure formatted according to the template generated for 
the user 'making the request. 

2. The server system of claim 1, wherein the 
plurality of user processes execute on a plurality of servers, 

25 the server system further comprising a means for assigning one 
of the plurality of servers to users who send requests to the 
server system but do not already have an associated user 
process . 

3 0 3. The server system of claim 2, wherein the means 

for assigning servers is a means for assigning a specific 
server to a particular user, such that the particular user is 
assigned the specific server for each request. 



35 4. The server system of claim 3, further comprising 

a cache for caching templates for recently serviced users on 
each of the specific servers assigned to particular users. 
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5. The server system of claim 1, further comprising 
a cache for caching templates for recently serviced users. 

6. The server system of claim 1, further comprising 
5 means for generating default user configurations based on user 

demographic information. 

7. The server system of claim 6, further comprising 
means for determining a default list of cities for a weather 

10 report and sports teams for sports reporting based on user 
demographic information. 

8. The server system of claim 7, wherein the means 
for determining the default list of cities and default lists 

15 of sports teams uses user postal code information, the server 
system further comprising: 

means for translating postal code information to 
user geographic position; 

means for comparing the user geographic position to 
20 geographic positions assigned to each city and sports team; 
and 

means for determining a threshold distance from the 
user geographic position which is greater than or equal to a 
distance to a predetermined nonzero number of cities and a 
25 predetermined nonzero number of sports team geographic 
positions • 

9. A method of serving custom news pages, 
comprising the steps of: 

30 collecting current security quotes for each of a 

plurality of selectable securities; 

collecting current sports news and scores for each 
of a plurality of selectable sports events; 

collecting current news headlines which reference 
35 news articles; 

formatting the current security quotes, current 
sports news and current news headlines into a data structure 
stored in a shared memory; 



I 1 
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accepting a request for a custom page from a user; 

in response to the request, reading a user template 
for the user from a template database, wherein the user 
template describes a layout of a custom news page customized 
5 for the user; 

populating a page based on the read user template 
and the current data stored in the data structure in the 
shared memory to form a custom news page; and 

providing the custom news page to the user in real- 
10 time response to the request. 
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<html> 
<head> 

<title>My Yahoo! news summary for <! — login — ></title> 

</head> 

<bociy> 

<center> 

<! — banner: sum — > 

<i~ ad — > 

C<1— nav bar — >> ~ 302 
</center> 

<table border=l cellpadding=4 cellspacing=0 width=100%"> 
<tr><td align=center va lign=top width="l%"> 
Q<1 — leftside : nsum — >) — ■ 302 

<p></td> 

<td align=center valign=top width="100%"> 
<!— mode bar : "FRONT_P AGE" — > 
(<1 — channel :nsum — >) — 302 

* 

</tdx/tr> 
</table> 

<center> 

<table border=l cellpadding=2 cellspacing=0 width=100%"> 

<! — motd : mot n .html — >. 

</table> 

</center> 

<! — search — > 

<! — copyright : sum — > 

</body> 
</html> 
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